<template>
  <div class="flex-center mb-16">
    <img src="@/assets/logo/logo_lark.svg " alt="" width="24px" class="mr-4"/>
    <h2>{{ $t('views.system.authentication.scanTheQRCode.larkQrCode') }}</h2>
  </div>
  <div id="lark-qr" class="lark-qrName"></div>
</template>

<script lang="ts" setup>
import {useScriptTag} from '@vueuse/core'
import {onMounted} from 'vue'
import {useRoute} from "vue-router";

const route = useRoute()
const {
  params: {accessToken},
} = route as any

const {load} = useScriptTag(
  'https://lf-package-cn.feishucdn.com/obj/feishu-static/lark/passport/qrcode/LarkSSOSDKWebQRCode-1.0.3.js'
)

const props = defineProps<{
  config: {
    app_secret: string
    app_key: string
  }
}>()

const initActive = async () => {
  const scriptLoaded = await load(true)
  if (!scriptLoaded) {
    console.error('飞书二维码 SDK 加载失败')
    return
  }

  const data = {
    agentId: props.config.app_key,
    appSecret: props.config.app_secret
  }
  const queryParams = new URLSearchParams(route.query as any).toString()
  const redirectUrl = encodeURIComponent(`${window.location.origin}/chat/api/auth/lark?accessToken=${accessToken}&${queryParams}`)
  //const redirectUrl = encodeURIComponent(`http://127.0.0.1:8080/chat/api/auth/lark?accessToken=${accessToken}&${queryParams}`)
  const url = `https://passport.feishu.cn/suite/passport/oauth/authorize?client_id=${data.agentId}&redirect_uri=${redirectUrl}&response_type=code&state=fit2cloud-lark-qr`

  const QRLoginObj = window.QRLogin({
    id: 'lark-qr',
    goto: url,
    width: '266',
    height: '266',
    style: 'width:280px;height:280px;border:1px solid #e8e8e8;margin:0 auto;border-radius:8px;'
  })

  window.addEventListener('message', async (event: any) => {
    if (QRLoginObj.matchOrigin(event.origin) && QRLoginObj.matchData(event.data)) {
      const loginTmpCode = event.data.tmp_code
      window.location.replace(`${url}&tmp_code=${loginTmpCode}`)
    }
  })
}

onMounted(() => {
  initActive()
})
</script>
<style scoped lang="scss"></style>
